## Watchdog Timer (WDT):

- The purpose of Watchdog Timer is to perform a system reset when system runs into an unknown state
- another function -> wake-up chip from power down mode.
- The watchdog timer includes an 18-bit free running counter with programmable time-out intervals.

| WTIS | Timeout Interval<br>Selection<br>T <sub>TIS</sub> | Interrupt Period<br>T <sub>INT</sub> | WTR Timeout startingInterval<br>(WDT_CLK=10 kHz)<br>MIN. T <sub>WTR</sub> ~ Max. T <sub>WTR</sub> |
|------|---------------------------------------------------|--------------------------------------|---------------------------------------------------------------------------------------------------|
| 000  | 2 <sup>4</sup> * T <sub>WDT</sub>                 | 1024 * T <sub>WDT</sub>              | 1.6 ms ~ 104 ms                                                                                   |
| 001  | 2 <sup>6</sup> * T <sub>WDT</sub>                 | 1024 * T <sub>WDT</sub>              | 6.4 ms ~ 108.8 ms                                                                                 |
| 010  | 2 <sup>8</sup> * T <sub>WDT</sub>                 | 1024 * T <sub>WDT</sub>              | 25.6 ms ~ 128 ms                                                                                  |
| 011  | 2 <sup>10</sup> * T <sub>WDT</sub>                | 1024 * T <sub>WDT</sub>              | 102.4 ms ~ 204.8 ms                                                                               |
| 100  | 2 <sup>12</sup> * T <sub>WDT</sub>                | 1024 * T <sub>WDT</sub>              | 409.6 ms ~ 512 ms                                                                                 |
| 101  | 2 <sup>14</sup> * T <sub>WDT</sub>                | 1024 * T <sub>WDT</sub>              | 1.6384 s ~ 1.7408 s                                                                               |
| 110  | 2 <sup>16</sup> * T <sub>WDT</sub>                | 1024 * T <sub>WDT</sub>              | 6.5536 s ~ 6.656 s                                                                                |
| 111  | 2 <sup>18</sup> * T <sub>WDT</sub>                | 1024 * T <sub>WDT</sub>              | 26.2144 s ~ 26.3168 s                                                                             |

## **WDT**: Timing



- T<sub>WDT</sub>: Watchdog Engine Clock Time Period
- T<sub>TIS</sub>: Watchdog Timeout Interval Selection Period
- T<sub>INT</sub>: Watchdog Interrupt Period
- T<sub>RST</sub>: Watchdog Reset Period
- T<sub>WTR</sub>: Watchdog Timeout Interval Period



## WDT: Block Diagram



- User must set WTR (WDTCR [0]) (Watchdog timer reset) high to reset the 18-bit WDT counter to avoid chip from Watchdog timer reset before the delay time expires. WTR bit is cleared automatically by hardware after WDT counter is reset.
- WTRF will not be cleared by Watchdog reset. User may poll WTRF by software to recognize the reset source.



| Register | Offset      | R/W | Description                     | Reset Value |
|----------|-------------|-----|---------------------------------|-------------|
| WTCR     | WDT_BA+0x00 | RW  | Watchdog Timer Control Register | 0x0000_0700 |

Note: All bits can be write in this register are write-protected. To program it needs to write "59h", "16h", "88h" to address 0x5000\_0100 to disable register protection. Reference the register REGWRPROT at address GCR\_BA+0x100.

| 31             | 30       | 29       | 28    | 27   | 26   | 25   | 24  |  |  |  |
|----------------|----------|----------|-------|------|------|------|-----|--|--|--|
| DBGACK_W<br>DT | Reserved |          |       |      |      |      |     |  |  |  |
| 23             | 22       | 21       | 20    | 19   | 18   | 17   | 16  |  |  |  |
| Reserved       |          |          |       |      |      |      |     |  |  |  |
| 15             | 14       | 13       | 12    | 11   | 10   | 9    | 8   |  |  |  |
|                |          | Reserved | WTIS  |      |      |      |     |  |  |  |
| 7              | 6        | 5        | 4     | 3    | 2    | 1    | 0   |  |  |  |
| WTE            | WTIE     | WTWKF    | WTWKE | WTIF | WTRF | WTRE | WTR |  |  |  |

## **WDT**: Program Example

```
void InitWDT (void)
  UNLOCKREG();
 /* Step 1. Enable and Select WDT clock source */
 SYSCLK->CLKSEL1.WDT S =3;//Select 10kHz for WDT clock source
 // 1 = external 32.768 kHz, 2 = HCLK/2048 clock, 3 = 10 kHz
 SYSCLK->APBCLK.WDT EN =1;//Enable WDT clock source
  /* Step 2. Select Timeout Interval */
  WDT->WTCR.WTIS=5:// WTR Timeout Interval = 1.6384 s ~ 1.7408 s
  /* Step 3. Disable Watchdog Timer Reset function */
  WDT->WTCR.WTRE = 0:
 /* Step 4. Enable WDT interrupt */
 WDT->WTCR.WTIF = 1;//Write 1 to clear
 WDT->WTCR.WTIE = 1:
  NVIC EnableIRQ(WDT IRQn);
  /* Step 5. Enable WDT module */
  WDT->WTCR.WTE = 1; //Enable WDT
  WDT->WTCR.WTR = 1; //Clear WDT counter
 LOCKREG();
void WDT IRQHandler(void)
 UNLOCKREG();
 WDT->WTCR.WTIF =1:
 WDT->WTCR.WTR = 1:
  UNLOCKREG();
 print lcd(3, "WDT interrupt");
```